<template>
  <div class="common-layout">
    <el-container>
      <div
        style="
          background: #fafad2;
          display: flex;
          height: 48px;
          justify-content: center;
          align-items: center;
          color: #696969;
        "
      >
        测试账号：123666 密码：w123666 毕设项目/前端辅导：w337674757
      </div>
      <!-- <div style='background:		#AFEEEE;display:flex;height:48px;justify-content: center;align-items: center;color:		#696969'></div> -->
      <el-header class="header-wrapped">
        <div class="header-content">
          <h3>通用后台管理系统</h3>
          <span class="welcome">欢迎您的登录</span>
        </div>
      </el-header>
      <el-main>
        <div class="login-wrapped">
          <el-card class="box-card">
            <el-tabs v-model="activeName" class="demo-tabs" :stretch="true">
              <el-tab-pane label="登录" name="first">
                <el-form class="login-form">
                  <el-form-item label="账号">
                    <el-input
                      v-model="loginData.account"
                      placeholder="请输入账号"
                    />
                  </el-form-item>
                  <el-form-item label="密码">
                    <el-input
                      v-model="loginData.password"
                      placeholder="请输入密码"
                      show-password
                    />
                  </el-form-item>
                  <!-- 底部外壳 -->
                  <div class="footer-wrapped">
                    <div class="forget-password">
                      <span class="forget-password-button" @click="openForget"
                        >忘记密码</span
                      >
                    </div>
                    <div class="footer-button">
                      <el-button type="primary" @click="Login">登录</el-button>
                    </div>
                    <div class="footer-go-register">
                      还没有账号？<span class="go-register">马上注册</span>
                    </div>
                  </div>
                </el-form>
              </el-tab-pane>
              <el-tab-pane label="注册" name="second">
                <el-form class="login-form">
                  <el-form-item label="账号">
                    <el-input
                      v-model="registerData.account"
                      placeholder="账号长度6-12位"
                    />
                  </el-form-item>
                  <el-form-item label="密码">
                    <el-input
                      v-model="registerData.password"
                      placeholder="密码需长度6-12位含字母数字"
                    />
                  </el-form-item>
                  <el-form-item label="确认密码">
                    <el-input
                      v-model="registerData.rePassword"
                      placeholder="请再次输入密码"
                    />
                  </el-form-item>
                  <div class="footer-button">
                    <el-button type="primary" @click="Register">注册</el-button>
                  </div>
                </el-form>
              </el-tab-pane>
            </el-tabs>
          </el-card>
        </div>
      </el-main>
      <el-footer class="footer-wrapped">
        <div class="footer-content">
          <div class="title">
            <span>网络工程师</span> | <span>全栈工程师</span> |
            <span>阿里云社区博客专家</span> | <span>CSND百万访问博主</span> |
            <span>清华大学出版社签约作家</span>
          </div>
        </div>
      </el-footer>
    </el-container>
  </div>
  <forget ref="forgetP"></forget>
</template>

<script lang="ts" setup>
import forget from './components/forget_password.vue'
import { ref, reactive } from "vue";
import {login,register} from '@/api/login.js'
import { useRouter } from 'vue-router';
import { ElMessage } from 'element-plus';
const router = useRouter();
const activeName = ref("first");
interface formData {
	account:number,
	password:string,
	rePassword?:string
}
// 登录表单数据
const loginData:formData = reactive({
  account: null,
  password: "",

});
// 注册表单数据
const registerData:formData = reactive({
  account: null,
  password: "",
  rePassword: "",
});
//登录
const Login = async ()=>{
  let res = await login(loginData);
  console.log('login',res)
  const {token} = res.data
  if(res.data.message == "登录成功"){
    ElMessage({
        message:'登录成功',
        type:'success'
    })
    localStorage.setItem('token',token)
    //跳转
    router.push('/home')
  }else{
    ElMessage.error('登录失败')
  }
}
const Register = async ()=>{
  if(registerData.password == registerData.rePassword){
    const res = await register(registerData);
    console.log('register',res)
    if(res.data.msg=='注册账号成功'){
      ElMessage({
        message:'注册账号成功',
        type:'success'
      })
      activeName.value = 'first'
    }else{
      ElMessage.error('注册失败,请检查数据是否正确')
    }
  }else{
    ElMessage.error('注册失败')
  }
  
}
//打开忘记密码弹窗
const forgetP = ref()
const openForget = ()=>{
	forgetP.value.open()
}
</script>

<style lang="scss" scoped>
// 头部外壳
.header-wrapped {
  // 头部内容
  .header-content {
    width: 1200px;
    margin: 0 auto;
    display: flex;
    justify-content: space-between;
    align-items: center;

    // 欢迎语
    .welcome {
      font-size: 13px;
    }
  }
}

// 主体部分
.el-main {
  background-image: url("@/assets/code.jpg");
  height: 600px;
  --el-main-padding: 0;

  // 登录外壳
  .login-wrapped {
    width: 1200px;
    height: 600px;
    margin: 0 auto;

    // 卡片样式
    .box-card {
      width: 350px;
      height: 375px;
      float: right;
      position: relative;
      top: 14%;

      .login-form {
        // 登录底部外壳
        .footer-wrapped {
          display: flex;
          flex-direction: column;

          .forget-password {
            display: flex;
            justify-content: flex-end;
            margin: 10px 0;

            .forget-password-button {
              font-size: 12px;
              color: #409eff;
              // 鼠标移入的效果
              cursor: pointer;
            }
          }

          .footer-go-register {
            font-size: 12px;
            margin: 12px 0;
            display: flex;
            justify-content: center;

            .go-register {
              font-size: 12px;
              color: #409eff;
              cursor: pointer;
            }
          }
        }

        // 底部登录按钮
        .footer-button {
          width: 100%;
          display: flex;
          justify-content: center;
        }
      }
    }
  }
}

// 底部外壳
.footer-wrapped {
  margin-top: 10px;

  // 底部内容
  .footer-content {
    width: 1200px;
    margin: 0 auto;
    display: flex;
    justify-content: center;
    align-items: center;

    // 底部介绍
    .title {
      color: #666;
    }

    span {
      color: #666;
      font-size: 12px;
    }
  }
}

// 表单边距
.el-form {
  margin-top: 30px;
}

// tabs标签
:deep(.el-tabs__item) {
  color: #333;
  font-size: 18px;
}

// 输入框高度
:deep(.el-input__inner) {
  height: 40px;
}

// 输入框标签字体高度
:deep(.el-form-item__label) {
  height: 40px;
  line-height: 40px;
}

// 登录按钮
:deep(.el-button) {
  width: 300px;
  height: 45px;
  font-size: 16px;
}
</style>
